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HIGHLY PARALLEL MAP DECODER 
BACKGROUND OF THE INVENTION 



I. Field of the Invention 

The present invention relates to coding. More particularly, the 
present invention relates to a novel and improved technique for 
performing maximum a posteriori probability (MAP) decoding. 

II. Description of the Related Art 

"Turbo coding" represents an important advancement in the area of 
forward error correction (FEC). There are many variants of turbo coding, but 

15 most use multiple encoding steps separated by interleaving steps combined 
with iterative decoding. This combination provides previously unavailable 
performance with respect to noise tolerance in a communications system. 
That is, turbo coding allows communications at E b /N 0 levels that were 
previously unacceptable using the existing forward error correction 

20 techniques. 

Manv svstems use forward error correction techniques, and therefore 
would benefit'from the use of turbo coding. For example, turbo codes could 
improve the performance of wireless satellite links where the limited 
downlink transmit power of the satellite necessitates receiver systems that 

25 can operate at low E b /N 0 levels. Using turbo codes in a wireless satellite link 
could reduce the dish size for a digital video broadcast (DVB) system, or 
alternative^, allow more data to be transmitted. 

Digital wireless telecommunication systems such as digital cellular 
and PCS telephone svstems also use forward error correction. For example, 

30 the IS-95 over-the-air interface standard, and its derivatives, such as 1S-95B, 
define a digital wireless communications system that uses convolutional 
encoding to provide coding gain to increase the capacity of the system. A 
svstem and method for processing RF signals substantially in accordance 
with the use of the IS-95 standard is described in U.S. Patent No. 5,103,4d9 

35 entitled "Svstem and Method for Generating Signal Waveforms in a CDMA 
Cellular Telephone System" assigned to the assignee of the present 
invention and incorporated herein by reference ('459 patent). 
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Many types of turbo coding require more complex circuitry than the 
previous available FEC coding techniques. For example, many turbo codes 
use maximum a posteriori probability (MAP) decoders, which are more 
complex than conventional Viterbi trellis decoders. For high data rate 
5 applications, the more complex MAP decoder can reduce the data rate at 
which data transmission can be performed. Thus, it would be highly 
desirable to have a MAP decoder that could operate at high data rates. 

SUMMARY OF THE INVENTION 

The present invention is a novel and improved technique for 
performing maximum a posteriori probability (MAP) decoding, with 
particular application to turbo, or iterative, coding techniques. In accordance 
with one embodiment of the invention, a set MAP decoders are applied in 
parallel to different sections of a frame symbol estimates to be decoded. Each 
MAP decoder generates decisions for the section of symbol estimates 
received. In one embodiment, initialization values are generated. The 
MAP decoders use the initialization values to start decoding at each section 
where the section begin at the middle of the frame. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The features, objects, and advantages of the present invention will 
become more apparent from the detailed description set forth below when 
25 taken in conjunction with the drawings in which like reference characters 
identify correspondingly throughout and wherein: 

FIGS. 1A and IB are block diagrams of turbo coders when configured 
in accordance with one embodiment of the invention; 

FIG. 2 is a block diagram of an interleaver when configured in 
30 accordance with one embodiment of the invention; 

FIGS. 3A and 3B are diagrams of PN code generators when configured 
in accordance with one embodiment of the invention; 

FIGS 5A and 5B are block diagrams of decoders configured in 
accordance with one embodiment of the invention; 
35 FIG. 6 is a graph illustrating the performance of one embodiment of 

the invention; 
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FIG. 7 is a graph illustrating the performance of another embodiment 
of the invention. 

Fig. 8 is a timing diagram illustrating the processing performed in 
accordance with one embodiment of the invention. 

5 

DETAILED DESCRIPTION OF THE PREFERRED 
EMBODIMENTS 

The present invention is a novel and improved technique for 

10 performing turbo coding. The exemplary embodiment is described in the 
context of the digital cellular telephone system. While use within this 
context is advantageous, different embodiments of the invention may be 
incorporated in different environments, configurations or digital data 
transmission systems, including satellite communication systems and wire 

15 line communication system such as digital cable and telephone systems. 

In general, the various systems described herein may be formed using 
software controlled processors, integrated circuits, or discrete logic, however, 
implementation in an integrated circuit is preferred. The data, instructions, 
commands, information, signals, symbols and chips that may be referenced 

20 throughout the application are advantageously represented by voltages, 
currents, electromagnetic waves, magnetic fields or particles, optical fields or 
particles, or a combination thereof. In addition, the blocks shown in each 
block diagram may represent either hardware or method steps. 

Fig. 1A is a highly simplified diagram of a cellular telephone system 

25 configured in accordance with one embodiment of the invention. To 
conduct telephone calls or other communications, subscriber units 10 
interface with base stations 12 via RF signals. Base stations 12 interface with 
the public switch telephone network via base station controller (BSC) 14. 

Fig. IB is a highly simplified diagram of a satellite communications 

30 system configured in accordance with another embodiment of the 
invention. Uplink station 40 transmits RF signals containing information 
such as video programming to satellite 42. Satellite 42 relays the RF signals 
back to earth where receiver 44 converts the receive RF signals into digital 
data. 

35 Fig. 2 is a block diagram of an exemplary transmit system configured 

in accordance with the use of one embodiment present invention. The 
transmit system can be used within a subscriber unit 10, a base stations 12, or 
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uplink station 40, as well as any other system that generates digital signals 
for transmission. The transmit processing shown represent just one 
possible embodiment of the invention, as numerous other transmit 
processing schemes may incorporate and benefit from the use of various 
5 embodiments of the invention. Data 70 is supplied to CRC generator 72 
which generates CRC checksum data for a given each predetermined 
amount of data received. 

The resulting data blocks are supplied to turbo coder 76 which 
generates code symbols that are supplied to channel interleaver 78. The 

10 code symbols typically include a retransmission of the original data (the 
systematic symbol), and one or more parity symbols. The number of parity 
symbols transmitted for each systematic symbol depends on the coding rate. 
For a coding rate of 1/2 one parity symbol is transmitted for every systematic 
symbol, for a total of two symbols generated for each data bit (including 

15 CRC) received. For a rate 1/3 turbo coder, two parity symbols are generated 
for each systemic symbol, for a total of three symbols generated for each data 
bit received. 

The code symbols from the turbo coder 76 are supplied to channel 
interleaver 78. Channel interleaver 78 performs interleaving on blocks of 

20 symbols as they are received, outputing interleaved symbols that are 
received by mapper 80. Typically, channel interleaver 78 performs block or 
bit-reversal interleaving, virtually all other types of interleavers many be 
used as the channel interleaver. 

Mapper 80 takes the interleaved code symbols and generates symbol 

25 words of certain bit width based on a predetermined mapping scheme. The 
symbol words are then applied to modulator 82 which generates a 
modulated wave form based on the symbol word received. Typical 
modulation techniques include QPSK, 8-PSK, and 16 QAM, although 
various other modulation schemes may be utilized. The modulated 

30 waveform is then upconverted for transmission at an RF frequency. 

Fig. 3A is a block diagram of a turbo coder configured in accordance 
with a first embodiment of the invention. In this first embodiment of the 
invention, the turbo coder is configured as a parallel concatenated turbo 
coder. Within the version of the turbo coder 76, constituent coder 90 and 

35 code interleaver 92 receive the data from CRC generator 72, which as 
described above output the input data and CRC checksum bits. As is well 
known, code interleaver 92 should be a highly randomized interleaver for 
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the best performance. An interleaver that provides excellent performance 
with minimal complexity as a code interleaver is described in copending 
U.S. Patent Application Serial No. 09/158,459 filed September 22, 1998 
entitled "Coding System Having State Machine Based Interleaver", and co- 
5 pending Continuation-In-Part Application Serial No. 09/172, 069, filed 
October 13, 1998 entitled "Coding System Having State Machine Based 
Interleaver", and U.S. Patent Application Serial No. 09/205,511 filed 
December 4, 1998 entitled "Turbo Code Interleaver Using Linear Cogruential 
Sequence". Constituent coder 90 outputs systematic symbols 94 (typically a 

10 copy of the original input bits) and parity symbols 96. Constituent coder 98 
receives the interleaved output of code interleaver 92 and outputs a second 
set of parity symbols 99. Other interleavers are known such at the 
interleaver described in the Cdma2000 common air interface standard. 

The outputs of constituent coder 90 and constituent coder 98 are 

15 muxed into the output data stream for a total coding rate R of 1/3. 
Additional constituent codes and code interleaver pairs may be added to 
reduce the coding rate for increased forward error correction. Alternatively, 
some of the parity symbols 96 and 99 may be punctured (not transmitted) to 
increase the coding rate. For example, the coding rate could be increased to 

20 _ by puncturing every other parity symbol 96 and 99, not transmitting parity 
symbol 96 at all. 

Constituent coders 90 and 98 may be various types of coders including 
block coders or convolutional coders. As convolutional coders, constituent 
coders 90 and 98 typically have a small constraint length such as 4 (four) to 

25 reduce complexity, and are recursive systematic convolutional (RSC) 
encoders. The lower constraint length reduces the complexity of the 
corresponding decoder at the receive system. Typically, the two coders 
output one systematic symbol and one parity symbol for each bit received for 
a constituent coding rate R = _. The total coding rate for the turbo coder of 

30 Fig. 1A is'R = 1/3, however, because the systematic bit from constituent 
coder 98 is not used. As noted above, additional interleaver and coder pairs 
may also be added in parallel to reduce the coding rate, and therefore 
provide higher error correction, or puncturing can be performed to increase 
the coding rate. 

35 Fig. 3B depicts turbo coder 78 as a serial concatenated turbo coder in 

accordance with an alternative embodiment of the invention. Within the 
turbo coder of Fig. 3B, the data from tail bit generator 74 is received by 
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constituent coder 110 and the resulting code symbols are applied to code 
interleaver 112. The resulting interleaved parity symbols are supplied to 
coder 114, which performs additional encoding to generate parity symbols 
115. Typically, constituent coder 110 (the outer coder) may be various types 
5 of encoders including block encoders or convolutional encoders, but 
constituent coder 114 (the inner coder) is preferably a recursive coder and is 
typically a recursive systematic encoder. 

As recursive systematic convolutional (RSC) encoders, constituent 
coders 110 and 114 generate symbols at a coding rate R < 1. That is, for a 

10 given number of input bits N, M output symbols are generated where M > 
N. The total coding rate for the serial concatenated turbo coder of Fig. IB is 
the coding rate of constituent coder 110 multiplied by the coding rate of 
constituent coder 114. Additional interleaver and coder pairs may also be 
added in series to reduce the coding rate and therefore provide additional 

15 error protection. 

Fig. 4 is a block diagram of a receive system configured in accordance 
with one embodiment of the invention. Antenna 150 provides the received 
RF signals to RF unit 152. RF unit performs downconvertion, filtering, and 
digitization of the RF signals. Mapper 140 receives the digitized data and 

20 provides soft decision data to channel deinterleaver 156. Turbo decoder 158 
decodes the soft decision data from channel deinterleaver 156 and supplies 
the resulting hard decision data to the processor or control unit at the 
receive system, which can check the accuracy of the data using the CRC 
checksum data. 

25 Fig. 5 is a block diagram of the processing of a frame of receive 

estimates in accordance with one embodiment of the invention. The frame 
100 of estimates are divided into N sections (portions) 102.0 - 102.N. Each 
section is provided to a MAP decoder engine 104.0B - 104.N. Each MAP 
engine performs MAP decoding over the section of receive estimates 

30 received. The resulting sections 108 of soft (or hard) decisions are output to 
make decision frame 106. 

In accordance with one embodiment of the invention, MAP engines 
104.0 - 104.N-1 processes a tail portion 103 of the section they receive, 
generating an initialization value 105 that is forwarded to the MAP engine 

35 104 processing the next section in the frame. The processing preferably 
comprises generating a set of forward state metrics over the last window 103. 
This processing results in a state metric that can be used as the initialization 
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state of the forward state metric of the MAP engine 104 receiving the state 
metric value. 

Last window 103 is preferably long enough to allow the state metric to 
arrive at a reliable state, which is typically at least three (3) times the 
5 memory length (K) of the RSC coder used in the encoder and preferably at 
least eight (8) times the memory length. In an alternative embodiment of 
the invention, the tail portion 103 may be supplied directly to the next MAP 
engine 104, as well as the corresponding MAP engine. That is, tail portion 
103 from section 102.X may be supplied to MAP engine 104.X+1, as well as 

10 . MAP engine 104.X. Each MAP engine 104 may then calculate its own 
initialization value. 

In the described embodiment, the MAP engines operate by first 
calculating forward state metrics and then calculating reverse state metrics. 
It is well known in the art that the reverse state metrics could be calculated 

15 first, and the then the forward state metrics would be calculated. In general, 
throughout the application the swapping of the reverse state metric 
calculators and the forward state metric calculators is consistent with the use 
of the invention. In the scheme of Fig. 4, if reverse state metric calculation 
was performed first, the tail portion 103 would be the first set of symbol 

20 estimates for each section, rather than the last, and each MAP engine 104.X 
would supply an initialization value to MAP engine 104.X-1, as should be 
apparent to those skilled in the art. 

By breaking up the frame into sections, and processing each section 
using a MAP engine, the rate at which frame can be processed is increased. 

25 Thus, higher data rate communications can receive the benefit of the greater 
Eb/NO performance of turbo coding. 

Fig. 6 is a block diagram of a MAP decoder configured in accordance 
with one embodiment of the invention. Frame buffer 300 stores a frame of 
symbol estimates. Within frame buffer 300, section buffers 302.0 - 302N store 

30 different sections of the frame. The sections are preferably completely 
different from one another to maximize efficiency, however, some overlap 
in the symbols estimates stored may also be employed. Each section buffer 
may be read from in substantially simultaneous fashion. 

MAP buffers 304.1 - 304.N receive symbol estimates from 

35 corresponding section buffers 304. Within MAP buffers 304 (as shown in 
detail by MAP buffer 304.1) window buffers 306.0 - 306.3 receive one window 
of symbol estimates from section buffer 302. A window is an amount of 
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symbol estimates that is substantially less than that stored in a section buffer 
302. A window is preferably at least four times the memory length (K) of the 
RSC encoding scheme used to perform encoding, and is typically about eight 
times the memory length. 
5 During operation, three of the four window buffers 306 read out 

symbol estimates to MAP engine 310 via multiplexers 308. The fourth 
window buffer 306 has symbol estimates written in from section buffer 302. 
Within MAP engine 310, the forward state metric calculator (FSMC) 312 
generates forward state metrics over a window of symbol estimates which 
10 are stored in metric buffer 316. Additionally, reverse state metric calculators 
(RSMC) generate reverse state metrics for other windows of symbol 
estimates. 

Preferably, the FSMC 412 and the RSMC 414 operate over windows of 
symbol estimates, so that metric buffer 416 only needs to store a window's 

15 worth of forward state metrics. This is contrast to other MAP decoding 
systems, which process the entire frame of symbol estimates in one direction 
(typically forward) before starting to process the entire frame in the next 
direction (typically reverse). Processing the entire section in this manner 
requires huge amounts of memory to store all the state metrics for the 

20 section, and therefore is not preferred. However, the use of MAP engines 
that process the entire section one direction before processing the section in 
the next direction is consistent with alternative embodiments of the 
invention. 

Multiplexer 318 applies one set of reverse state metrics to log 
25 likelihood ratio calculator (LLR) 320 which calculates the log likelihood ratio 
of the forward and reverse state metrics to generate extrinsic information. 
The extrinsic information can be used to perform another iteration of 
decoding in accordance with the iterative decoding techniques of turbo 
coding. The other reverse state metric calculator generates an initialization 
30 state for use during the decoding of the next window of symbol estimates. 

Additionally, in accordance with one embodiment of the invention, 
FSMC 312 processes the end portion (last window) of the section it is 
processing (i.e. the set of symbols stored in the corresponding section buffer 
302). This last window processing generates an initialization state 330 that 
35 is passed to the next MAP engine 312 for processing the next section of 
symbol estimates in the frame. For example, MAP engine 310.0 would pass 
the initialization state 330 to MAP engine 310.1. Typically, the first MAP 
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engine 310.0 does not need an initialization state because the state of the 
coding at the start of the frame is known. Additionally, the state of the 
encoder at the end of the frame is preferably known, via the use of tail bits 
added to the frame during transmit processing, which is well known in the 
5 art. In an alternative embodiment of the invention, a MAP engine 310 will 
initialize itself by processing the last window of the previous section in the 
frame. It should be noted that the window used for initialization (last 
window) and the windows used during the processing of the section do not 
have to be the same length. 

10 A similar system and method for operating MAP buffer 304 in 

conjunction with a MAP engine 310 is described in copending U.S. Patent 
Application Serial No. 09/283,013 entitled "MEMORY ARCHITECTURE 
FOR MAP DECODER" filed on March 31, 1999, assigned to the assignee of 
the present invention and incorporated herein by reference. Additionally, a 

15 system and method for implementing a sliding window MAP engine is 
described in U.S. Patent No. 5,933,462, issued August 3, 1999, entitled "Soft 
Decision Output Decoder for Decoding Convolutionally Encoded 
Codewords" assigned to the assignee of the present invention and 
incorporated herein by reference. 

20 Fig. 7 is a block diagram of a highly simplified MAP decoder 

configured in accordance with a second embodiment of the invention. The 
embodiment of Fig. 7, does not provide the same performance as that of Fig. 
6, but significant improvement in the data rate processing ability is still 
provided. Frame buffer 400 holds a frame of symbol estimates. Frame 

25 buffer 400 is comprised of a set of section buffers 402, which in turn are 
comprised of section banks 404. A and 404.B. MAP engines 410 receive 
symbol estimates from corresponding section buffers 402 via multiplexers 
408. MAP engine 410.0 is shown in detail. 

Within a MAP engine 410.0, forward state metric calculator (FSMC) 

30 412 generates forward state metrics in response to symbol estimates received 
from section buffer 402. The forward state metrics are stored in metric buffer 
416. Reverse state metric calculator (RSMC) 413 generates reverse state 
metrics which are applied to log-likelihood ratio calculator (LLR) 418. LLR 
418 performs a log-likelihood ratio calculation on the forward and reverse 

35 state metrics and outputs soft decision data (typically extrinsic data) that can 
be used to conduct another decoding iteration or to generate hard decisions. 
The other MAP engines 410 and section buffers 402 operate in a similar 
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manner, at substantially the same time, with one notable exception being 
J that the last MAP engine 410.N does not generate an initialization state 
(value) for the next MAP engine. 

Preferably, the FSMC 412 and the RSMC 414 operate over windows of 
5 symbol estimates, so that metric buffer 416 only needs to store a window's 
worth of forward state metrics (or two windows for a double buffered 
memory). Additionally, it is preferable to have FSMC 412 and RSMC 414 
operate at the same time when possible to further reduce processing time. 
In an exemplary processing, FSMC 412 processes a first window (L) of symbol 

10 estimates while RSMC 414 simultaneously processes the next (sequential) 
window of symbol estimates (2L). Once FSMC 412 completes processing 
widow L, RSMC 414 begins processing window L using the starting state 
generated during the processing window 2L, with the results going to LLR 
418 as described above. This processing continues for the set of windows 1 ... 

15 M making up the frame, with FSMC 412 processing window j*L and RSMC 
414 processing windows (j+l)L and j*L. Additionally, in one embodiment of 
the invention, FSMC 412 first processes a set of estimates at the end of the 
section of symbol estimates (for example the last window M*L of symbol 
estimates) to generate an initialization state 422. The initialization state 422 

20 is passed to the next MAP engine 410.1. MAP engine 410.1 also generates an 
initialization state 422, and then start FSMC processing using the 
initialization state received from MAP engine 410.0. 

In the embodiment of the invention shown in Fig. 7, section buffers 
402 are divided into two banks 404 that may be written or read from 

25 simultaneously. This allows simultaneous processing by FSMC 412 and 
RSMC 414 which increases efficiency. A system and method for performing 
MAP decoding that uses a partitioned frame buffer is described in copending 
. U.S. Patent Application Serial No. 09/259,665 entitled "PARTITIONED 
INTERLEAVER MEMORY FOR MAP DECODER" filed on February 26, 1999 

30 assigned to the assignee of the present invention and incorporated herein by 
reference. The system described in this patent partitions the memory into 
three banks, however, the same principles of operation are applicable. In 
one embodiment of the invention shown in Fig. 7, every even (2L, 4L, 2*jL) 
window of symbol estimates is stored in one bank 404 and every odd 

35 window (1L, 3L ...2(j+l)L) of symbol estimates is stored in the other bank 
404. Storing in this fashion allows FSMC 412 and RSMC 414 to access 
different portions of the section simultaneously. Other distributions of the 
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symbol estimates within the two banks 404 that allow simultaneous access 
to by FSMC 412 and RSMC 414 should be apparent and are consistent with 
the use of the present invention. 

In an alternative embodiment of the invention, a MAP buffer similar 
5 to that shown in Fig, 6 may be employed in the system of Fig. 7. In this 
configuration, section buffer 402 is comprised of a single bank, rather than 
partitioned. Also, the number of window RAMs in the MAP buffer would 
be three, rather than the four shown in Fig. 6, because one less state metric 
calculator is used. 

10 Conversely, the partitioned memory of Fig 7, where the section 

buffers are divided, could also be employed in the embodiment of Fig. 6. For 
example, MAP buffers 304 could be removed, and section buffers 302 (Fig. 6) 
partitioned into three banks for simultaneous access by FSMC 312 and 
RSMCs 314.0 and 312.1. In this embodiment the operation of the section 

15 buffer 402 would be similar to the frame buffer described in copending U.S. 
Patent Application Serial No. 09/259,665 entitled "PARTITIONED 
INTERLEAVER MEMORY FOR MAP DECODER". 

In a still more simplified embodiment of the invention, a single state 
metric calculator, capable of generating both forward and reverse state 

20 metrics could be used in each MAP engine. Once again, this reduces the rate 
at which data can be processed relative the other embodiments, but still 
provides highly parallel operation when combined with the use of multiple 
MAP engines working on different sections of a frame. 

While the use of a sliding window MAP engine as described in the 

25 various embodiments is preferred, because it reduces the size. of any metric 
buffers such as metric buffers 416 or 316, they are not necessary. For 
example, a set of MAP engines that decode entire sections of symbol in one 
direction before starting to decode the section in the other direction are 
consistent with the use of some aspects of the invention. 

30 In a typical transmit system, the frame buffers 200 and 400 are used as 

channel deinterleaver memory as well, with the deinterleaving being done 
by writing data in, or reading data out, using the interleaved address 
sequence. Additionally, in other embodiments each section buffer may 
contain overlapping portions (sections) of the frame. These overlapping 

35 sections allow each MAP engine to initialize itself, and therefore removes 
the need to transfer initialization states between MAP engines. 
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In still other embodiments, each MAP engine may process each 
section without the use of initialization states. This embodiment has 
reduced complexity, but the coding accuracy is severely reduced. 

Fig. 8 is a timing diagram illustrating the processing performed by a 
5 MAP engine during the decoding of a section of a frame when performed in 
accordance with one embodiment of the invention. The timing diagram is 
described with reference to the structures of Fig. 6 for convenience, but 
various other implementation my use the exemplary timing provided. 

During a first time slot (1), the MAP engine 310 processes the Mth 
10 (last) window of symbol estimates using the FSMC 312. The state of FSMC 
312 is then forwarded to the next MAP engine 310 as the initialization state 
330. 

During the next time slot (2), FSMC 312 processes the first window of 
symbol estimates (1L) and the RSMC 314.0 processes the second window of 

15 symbol estimates (2L). During the third time slot (3), RSMC 314.1 processes 
the third (3L) window of symbol estimates, and RSMC 314.0 processes the 
first window (1L) of symbol estimates being properly initialized by the 
processing of the second window of symbol estimates during the second 
time slot, with the initialization being indicated by the (I). The processing 

20 continues until the forward state metrics and reverse state metrics are 
generated for each window in the section of the frame. As noted above, 
each MAP engine performs this type of processing on each section, allowing 
the frame to be processed in its entirety in an extremely rapid, highly 
parallel, fashion. 

25 Thus, a novel and improved technique for performing highly parallel 

MAP decoding has been described. The previous description of the preferred 
embodiments is provided to enable any person skilled in the art to make or 
use the present invention. The various modifications to these 
embodiments will be readily apparent to those skilled in the art, and the 

30 generic principles defined herein may be applied to other embodiments 
without the use of the inventive faculty. Thus, the- present invention is not 
intended to be limited to the embodiments shown herein but is to be 
accorded the widest scope consistent with the principles and novel features 
disclosed herein. 

35 
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CLAIMS 



1. A system for performing MAP decoding comprising: 

2 a) set of MAP engines, each for decoding a corresponding 

different portion of a frame of symbol estimates, where each portion is 
4 substantially different from another portion; 

b) set of memory elements, each for simultaneously providing at 
6 least one of said different portions to a corresponding MAP engines. 

2. The system as set forth in claim one wherein said frame of 
2 symbol estimates has a known starting state and a known ending 

state. 



3. The system as set forth in claim 1 wherein some of said set of 
2 MAP engines generate initialization values from said 

substantially different portion of said set of symbol estimates. 

4. The system as set forth in claim 1 wherein each of said some of 
2 said set of MAP engines provide said initialization data to another 

MAP engine. 

5. The system as set forth in claim 1 wherein some of said set of 
2 MAP engines generate initialization values from portion of said set of 

symbol estimates that is not said corresponding portion of said symbol 
4 estimates. 



6. A circuit for performing MAP decoding comprising: 
2 first memory element for reading out a first symbol estimate frame 

portion, wherein said first symbol estimate frame portion has a known start 
4 state; 

second memory element for reading out a second symbol estimate 
6 frame portion; 

first MAP decoder unit for deciding said first symbol estimate frame 
8 portion; 

second MAP decoder for decoding said second symbol estimate frame 
10 portion. 
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7. The circuit as set forth in claim 6 wherein said first MAP 
2 decoder generates an initialization value by decoding a last portion of said 

fist symbol estimate frame portion and said initialization value is provided 
4 to said second MAP decoder. 

8. The circuit as set forth in claim 6 wherein said second MAP 
2 decoder generates an initialization value from a last portion of first 

symbol estimate. 

9. The circuit as set forth in claim 6 wherein said MAP decoder 
2 engine is comprised of: 

forward state metric calculator for generating forward state 

4 metrics; 

reverse state metric calculator for generating reverse state 

6 metrics. 

10. The circuit as set forth in claim 6 wherein said first MAP 
2 decoder engine is comprised of: 

first state metric calculator for generating first direction state 
4 metrics in response to said first set of receive estimates; 

second state metric calculator for generating a first set of second 
6 direction state metrics; and 

third state metric calculator for generating a second set of 
8 second direction state metrics. 

11. The decoder as set forth in claim 10 further comprising: 

2 first decoder buffer for receiving symbol estimates from said first 

memory element and writing symbol estimates to said first MAP decoder 
4 engine. 

12. The decoder as set forth in claim 11 wherein said first decoder 
2 buffer is comprised of four memories, each for reading out and 

writing in symbol estimates, wherein three of said four memories are 
4 reading out symbol estimates, and one of said four memory is reading 

in symbol estimates. 



13. A circuit for performing MAP decoding comprising: 
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2 first memory element for reading out a first symbol estimate frame 

portion, wherein said first symbol estimate frame portion has a known start 
4 state; 

second memory element for reading out a second symbol estimate 
6 frame portion; 

first MAP decoder unit for decoding said first symbol estimate frame 
8 portion in windows, and for providing an initialization value; 

second MAP decoder for decoding said second symbol estimate frame 
10 portion in windows in windows, and for initializing using said 
initialization value. 

14. The circuit as set forth in claim 13 wherein said first MAP 
2 decoder engine is comprised of: 

first state metric calculator for generating first direction state metrics 
4 in response to said first set of receive estimates; 

second state metric calculator for generating a first set of second 
6 direction state metrics; and 

third state metric calculator for generating a second set of second 
8 direction state metrics. 

15. A circuit for performing MAP decoding on a frame of symbol 
2 estimates, said frame having a known starting state and a known ending 

state, comprising: 

4 first sliding window MAP decoder for receiving a first portion of said 

frame, said first sliding window MAP decoder having a set of state metric 
6 calculators for generating state metric calculation over windows of said first 

portion of said frame; 
8 second sliding window MAP decoder for receiving a second portion 

of said frame, said first sliding window MAP decoder having a set of state 
10 metric calculators for generating state metric calculation over windows of 

said first portion of said frame. 

16. The circuit as set forth in claim 15 further comprising: 

2 first memory bank for reading said first portion of said frame to said 

first sliding window MAP decoder; 
4 second memory bank for reading said second portion of said frame to 

said second sliding window MAP decoder. 
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17. The circuit as set forth in claim 15 further comprising a third 
2 sliding window MAP decoder for receiving a, third portion of said frame, 

said first sliding window MAP decoder having a set of state metric 
4 calculators for generating state metric calculation over windows of said first 
portion of said frame. 

18. The circuit as set forth in claim 15 wherein said first sliding 
2 window MAP decoder comprising a first state metric calculator and a second 

state metric calculator. 

19. The circuit as set forth in claim 18 wherein said first sliding 
2 window MAP decoder further comprising a third state metric 

calculator. 



1 



WO 00/59118 PCT/US00/40042 

1/9 




WO 00/59118 



2/9 



PCT/USOO/4004 




WO 00/59118 



PCT/LS00/4004 



3/9 




oo 



Pi 

a: ^ 

2 



O 

CO 

=> O 




o 



WO 00/59118 



A/9 



PCT/USOO/40042 



X 
2 



o 

Os 



ON 



On 
On 







Z 




UJ 

ZD 


w 


NSTl' 




CO 


O 




o 





H 






Z 






U3 
ID 

L— r 


ER 




UJ 04 


.LSN 


CO 


O 






o 







ON 









uj 




> 




< 


Q 


uj 


CO 


TERL 




z 





< 
b 



UJ 

> 
< 

UJ 
>—! 

aL 

UJ 















i— . 


ER 


H 
on 

Z 


Q cm 


CO 


o 






u 









of 




UJ 




> 


UJ 


< 


Q 


UJ 


CO 


ERL 




i— . 




z 








WO 00/59118 



PCT/USOO/40042 



5/9 



O 



O 
Z 

o 
o 

DO 

w 
o 



oo 







o 






Q 




O 






H 




Q 











-J 


LEAV 


< 






H 








5 




Q 



b 

i— i 



•3- 
io 


MAPPER 




i 




CM 
iO 






Li- 


UNIT 




j 











WO 00/59118 



PCT/US00/40042 



6/9 










a- z 










o| 




o 



o » 



4 



4 



4 



4 







or) 

z 
o 

a: 
Q 



O 

GO 

c 

CD 



WO 00/59118 



7/9 



PCT/USOO/40042 




ID 

CO 
2 



2 




O 








SEC 


en 



WO 00/59118 



PCT/USOO/40042 



8/9 



2 




W O 00/59118 



PCT/USOO/4004 



9/9 



X 



X 



— ] 



01 



OO 

2 



oo 



INTERNATIONAL SEARCH REPORT 



Inte jonai Application No 

PCT/US 00/40042 



CLASSIFICATION OF SUBJECT MATTER 

PC 7 H03M13/29 



According to Interna 



tional Patent Classification (IPC) or to both national classification and lPC_ 



B. FIELDS SEARCHEO 



Minimum documentation searcned (classification system followed by classification symbols) 

PC 7 H03M H04L 



Documentation searched oiher 



;han min.mum documentation to the extent that such documents are included in the fields searched 



Electronic data base consulteo dur.ng the .ntemationai search (name of data base and. where practical, search terms used) 

INSPEC, COMPENDEX , EPO-Internal 



C. DOCUMENTS CONSIDERED TO BE RELEVANT 



Category c Citation of document, with indication, where appropriate, ot the relevant passages 



Relevant to claim No. 



HSU J-M ET AL: "A parallel decoding 
scheme for turbo codes" 
IEEE INTERNATIONAL SYMPOSIUM ON CIRCUITS 
AND SYSTEMS, US, NEW YORK, NY: IEEE, 

31 May 1998 (1998-05-31), pages 445-448, 
XP002124484 
ISBN: 0-7803-4456-1 

paragraph '0003!; figures 3-6 



1,2,6, 
10,15, 18 



3-5, 

11-14, 

16,17,19 



Further documents are listed in the continuation of box C 



0 



Patent family members are listed in annex. 



• Special categones of cited documents : 

"A' document defining the general state of the art which is not 

considered to be of particular relevance 
M E" earlier document but published on or after the international 

filing date 

"L" document which may throw doubts on priority claim(s) or 
which is cited to establish the publication date ot another 
citation or other special reason (as specified) 

"O" document referring to an oral disclosure, use. exhibition or 
other means 

"P" document published prior to the international filing date but 
later than the priority date claimed 



T" later document published after the international filing date 
or priority date and not in conflict with the application but 
cited to understand the principle or theory underlying the 
invention 

"X" document of particular relevance; the claimed invention 
cannot be considered novel or cannot be considered to 
involve an inventive step when the document is taken alone 

"V* document of particular relevance: the claimed invention 

cannot be considered to involve an inventive step when the 
document is combined with one or more other such docu- 
ments, such combination being obvious to a person skilled 
in the art. 

document member of the same patent family 



Date ot the actuai completion ot the international search 



30 August 2000 



Date ot mailing of the international search reoort 



06/09/2000 



Name ana mailing address ot the ISA 

European Patent Office. P.3. 5818 Patentlaan 2 
NL - 2280 KV flijswijk 

Tel. (+31-70) 3^0-2040. Tx. 31 651 epo nJ. 
Fax: (+31-70) 340-3016 



Authorized officer 



Berbain, F 



Form PCTlS^2iO*secono sneei».Ju»y 1952) 



page 1 of 2 



INTERNATIONAL SEARCH KLrUKi 


Inte onal Application No 

PCT/US 00/40042 


C.(Continuation) DOCUMENTS CONSIDERED TO BE RELEVANT 




Categor/ ' 


Citation oi document, with indication.where appropriate, ot tne relevant passages 


Relevant to claim No. 


X 
A 


OAWID H ET AL: "Map channel decoding: 
Algorithm and VLSI architecture" 
VLSI SIGNAL PROCESSING , PROCEEDINGS. IEEE 
WORKSHOP ON VLSI SIGNAL PROCESSING , XX , XX . 
vol. 6, no. VI, 

20 October 1993 (1993-10-20). pages 
141-149. ABSTRACT-149. XP002113702 
paragraphs '0003! , '0005! ; figures 2-4 




1,2.6, 
10,15, 13 

3-5, 
11-14, 
16,17, 19 


A 


BENEDETTO S ET AL: "SOFT-OUTPUT DECODING 
ALGORITHMS FOR CONTINUOUS DECODING OF 
PARALLELCONCATENATED CONVOLUTIONAL CODES" 
IEEE INTERNATIONAL CONFERENCE ON 
COMMUNICATIONS (ICC), US, NEW YORK, IEEE, 

23 June 1996 (1996-06-23), pages 112-117, 
XP000625652 
ISBN: 0-7803-3251-2 

paragraph * 0 1 1 1 ! 




1-19 


A 


W0 98 20617 A (QUALC0MM INC) 

14 May 1998 (1998-05-14) 

page 12, line 26 -page 16, line 14 




1-19 



=orm ?CT 1SA.210 .cctitmuauen ol second sneetl iJmy i*92V 



page 2 of 2 



INTERNATIONAL SEARCH REPORT 

information on patent family members 



Inte onal Application No 

PCT/US 00/40042 



Patent document 
crted in search report 


Publication 
date 


Patent family 
member(s) 


Publication 
date 


WO 9820617 A 


14-05-1998 


us 


5933462 


A 


03-08-1999 




AU 


5104598 


A 


29-05-1998 






CN 


1236507 


A 


24-11-1999 






EP 


0937336 


A 


25-08-1999 



form PCT !SA-2tO (patsni lamdy annex) fJuly I992J 



